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Amendments to the Claims 

Please cancel Claims 24-54 and 73-87. Please amend Claims 7, 6, 7, P, 13, 14, 16, 17, 
20, 21, 23, 55, 61, 66, 67, 72, 88, 91, 94, and 97. Please add new Claims 98-100. The Claim 
Listing below will replace all prior versions of the claims in the application: 

Claim Listing 

1. (Currently Amended) A method of developing computer software [[from]] using an 
electronic spreadsheet, the method comprising the computer implemented steps of: 

creating an object-oriented programming environment for developing computer 
software by: 

representing an object in an object-oriented programming language using 
one or more electronic spreadsheets; 

coupling content in at least one cell of [[an]] one of the electronic 
spreadsheets to a windo w, where the content in the cell includes instructions for 
the object : and 

determining properties of the window based on the content in the cell of 
the one spreadsheet. 

2. (Original) A method of developing computer software according to Claim 1 wherein the 
step of coupling content in at least one cell of an electronic spreadsheet to a window 
fiirther includes determining any graphical or fimctional attributes, associated with the 
content in the cell to construct the window. 

3. (Original) A method of developing computer software according to Claim 1 wherein the 
content in the cell of the spreadsheet corresponds to the properties of the window in that 
any changes to the properties of the window are reflected in the content in the cell. 

4. (Original) A method of developing computer software according to Claim 1 wherein the 
step of coupling the content is in response to determming that an event has occurred. 
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(Original) A method of developing computer software according to Claim 4 wherein the 
step of determining that an event has occurred includes determining that a drag and drop 
event type has occurred in that the content in the cell has been dragged from the cell to 
the window, and subsequently dropped onto the window. 

(Currently Amended) A method of developing computer software according to Claim 5 
fiirther includes the step of responding to the dropping of the content from the cell onto 
the window by: 

(a) processing the content in the cell; and 

(b) determining the properties of the window based on the content in the cell 
including determining any desired behavior of the object, including [[or]] any desired 
appearance of the window to depict the object b ased on the content in the cell. 

(Currently Amended) A method of developing computer software according to Claim 1 
wherein the content in one of t he cells include cell includ e s any attributes associated with 
the cell. 

(Original) A method of developing computer software according to Claim 7 wherein the 
attributes include any input field, check box, radio button, menu object, popup menu 
object, label, button, combo box or list box. 

(Currently Amended) A computer program product comprising: 

a computer usable medium which includes computer readable program 
instructions for developing object-oriented computer software with an electronic 
spreadsheet by: 

(i) representing an object in an object-oriented programming language 
using one or more electronic spreadsheets: 

(iiV-(+> processing content associated with a cell of [[an]] one of the 
electronic spreadsheets; 
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(iii) (ii) connecting the content [[in]] associated with the cell to a window^ 
where the content in the cell includes instructions for the object : and 

£iv} (iii) using the content associated with the cell, determining any 
attributes of the window. 

10. (Original) A computer program product according to Claim 9 wherein the instructions 
for connecting the content associated with the cell to a window further include 
instructions for assembling any graphical or functional attributes associated with the 
content in the cell to construct the window. 

1 1 . (Original) A computer program product according to Claim 9 wherein the instructions 
for connecting the content associated with the cell to a window are in response to 
receiving an indication that an event has occurred. 

12. (Original) A computer program product according to Claim 1 1 wherein receiving an 
indication that an event has occurred includes determining that a drag and drop event type 
has occurred such that the content associated with the cell is dragged firom the cell to the 
window, and subsequently dropped onto the window. 

13. (Currently Amended) A computer program product according to Claim 12 further 
includes instructions that respond to the dropping of the content onto the window by: 

(a) processing the content associated with the cell; and 

(b) determining the attributes of the window based on the content associated with 
the cell including determining any desired behavior of the object, including [[or]] any 
desired appearance of the window to depict the object based on the content associated 
with the cell . 

14. (Currently Amended) A computer program product according to Claim 9 wherein the 
content associated with one of t he c e ll includ e s cells include any data objects associated 
with the cell. 
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15. (Original) A computer program product according to Claim 14 wherein the data objects 
associated with the cell include any input field, check box, radio button, menu object, 
popup menu object, label, button, combo box or list box. 

16. (Currently Amended) An apparatus for developing computer software using an 
electronic spreadsheet, the apparatus comprising: 

(a) an object in an object oriented programming language: 
£b]L[[(a)]] an electronic spreadsheet representing the object, the spreadsheet 
having at least one input cell; 

(c) [[(b)]] instructions in the cell , the instructions including instructions for the 
object : and 

(d) [[(c)]] a window which reflects the instructions in the cell. 

17. (Currently Amended) An apparatus according to Claim 16 further including an assembly 
which: 

processes the instructions in the cell; and 

connects the instructions from the cell to the to th e window. 

18. (Original) An apparatus according to Claim 1 7 wherein the assembly connects the 
instructions to the window in response to receiving an indication that an event has 
occurred. 

19. (Original) An apparatus according to Claim 18 wherein receiving an indication that an 
event has occurred includes determining that a drag and drop event type has occurred 
where the instructions in the cell are dragged from the cell to the window, and 
subsequently dropped onto the window to construct the window. 

20. (Currently Amended) An apparatus according to Claim 19 wherein the assembly 
responds to the dropping of the instructions onto the window by: 
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processing the instructions in the cell; and 

determining the attributes of the window based on the instructions in the cell to 
define a behavior of the object or appearance for the window to depict the object . 

21. (Currently Amended) An apparatus according to Claim 16 wherein the instructions in 
one of the cells th e cell describe attributes associated with the cell. 



22. (Original) An apparatus according to Claim 21 wherein the attributes include any input 
field, check box, radio button, menu object, popup menu object, label, button, combo box 
or list box. 

23. (Currently Amended) A system to develop computer software in a spreadsheet 
application, the system comprising: 

means for representing an object in an object-oriented programming language 
using one or more electronic spreadsheets; 

[[a]] means for coupling instructions associated with at least one cell of aft 
e l e ctronic one of the spreadsheets to a windo w, where the content in the cell includes 
instructions for the object : and 

[[a]] means for determining properties of the window based on any instructions 
associated with the cell of the one spreadsheet. 



24.-54. (Cancelled). 



55. (Currently Amended) A method of providing text editor functionality in an electronic 
spreadsheet, the method comprising the computer implemented steps of: 

creating a software progranuning environment using an electronic spreadsheet in 
which computer software code is programmed using the spreadsheet: 

defining a code column to program the computer software code in an e l e ctronic 
the spreadsheet; and 

responding to a request for a newline by inserting a new cell in the code column. 
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56. (Original) A method according to Claim 55 wherein the code column further includes 
text editor functionality in that the code column behaves as a text editor. 

57. (Original) A method according to Claim 56 wherein the request for a newline occurs 
when a keystroke input is received while a cell in the code column is selected. 

58. (Original) A method according to Claim 57 further includes: 

inserting the new cell below the selected cell; 

moving cells positioned below the selected cell to create space for the new cell; 

and 

correcting any references to the cells which are moved. 

59. (Original) A method according to Claim 55 wherein the code colunm further includes 
scroll bars. 

60. (Original) A method of computer programming according to Claim 58 wherein the scroll 
bars enable scrolling through the code column independent of any scrolling of the 
spreadsheet, 

61 . (Currently Amended) A computer program product comprising: 

a computer usable medium having computer readable program instructions which 
implement a computer programming environment in an electronic spreadsheet by: 
creating a software programming environment using an electronic 
spreadsheet in which computer software code is programmed using the 
spreadsheet: 

creating a code colunm to program the computer software code in aft 
e lectronic the spreadsheet: and 

responding to a request for a newline by introducing a new cell in the code 
column. 
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62. (Original) A computer program product according to Claim 61 wherein the code column 
provides text editor functionality. 

63. (Original) A computer program product according to Claim 62 wherein the request for a 
newline is determined in response to receiving a keystroke input while a cell in the code 
column is selected. 

64. (Original) A computer program product according to Claim 63 further includes 
instructions for: 

inserting the new cell below the selected cell; 

adjusting cells positioned below the selected cell to provide space for the new 
cell; and 

in a cell that includes a reference to one of the adjusted cells, correcting the 
reference. 

65. (Original) A computer program product according to Claim 62 wherein the code column 
further includes scroll bars. 

66. (Currently Amended) A computer program product according to Claim [[62]] 65 
wherein the scroll bars enable scrolling through the code column independent of any 
scrolling of the spreadsheet. 

67. (Currently Amended) An apparatus for developing computer software from an electronic 
spreadsheet comprising: 

a software programming environment that is implemented in an electronic 
spreadsheet in which computer software code is progranmied using the spreadsheet: 

a code colunm to program the computer software code in an e l e ctronic the 
spreadshee t, where the code column is responsive that r e sponds t o a request for a newline 
by introducing a new cell in the code column. 
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68. (Original) An apparatus according to Claim 67 wherein the code column is a text editor 
in a column of the spreadsheet. 

69. (Original) An apparatus according to Claim 67 wherein the request for a newline occurs 
when a keystroke input is received while a cell in the code colunm is selected. 

70. (Original) An apparatus according to Claim 67 further includes logic for: 

inserting the new cell below the selected cell; 

adjusting the position of the cells below the selected cell to account for the new 
cell; and 

updating a reference to one of the adjusted cells to reflect a new position for the 
adjusted cell 

71 . (Original) An apparatus according to Claim 67 wherein the code column in the 
spreadsheet includes scroll bars which enable scrolling through the code column 
independent of any scrolling of the spreadsheet. 

72. (Currently Amended) A system for developing computer software in an electronic 
spreadsheet comprising: 

means for implementing a software programming environment using an electronic 
spreadsheet in which computer software code is programmed from the spreadsheet 

[[a]] means for defining a code column to program the computer software code in 
an electronic the spreadsheet; and 

[[a]] means for responding to a request for a newline by inserting a new cell in the 
code colunm. 

73. -87. (Cancelled). 
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ss. (Currently Amended) A method of progranmiing with an electronic spreadsheet, the 
method comprising the computer implemented steps of: 

implementing a computer software progranmiing environment using [f a ]] an 
electronic spreadsheet [Tbyll including creating a software program using the spreadsheet: 
defining cells in [[a]]the spreadsheet that are associated with an iterative 
process repeating for one or more cycles , where the iterative process repeats the 
same action until a condition no longer applies ; and 

at each cycle, determining whether to modify content in the cells 
associated with the iterative process , where resulting modified content causes 
changes to the software program being created using the spreadsheet . 

89. (Original) A method of programming with an electronic spreadsheet as in Claim 88 
wherein at least one of the cells associated with the iterative process includes a final 
value cell, and at least one of the cells includes an initial value cell, where a value in the 
final value cell is used to modify a value in the initial value cell. 

90. (Original) A method of programming with an electronic spreadsheet as in Claim 88 
wherein the iterative process is repeated for either a fixed number of times or until a 
condition defined in a condition cell no longer applies, or begins to apply. 

91 . (Currently Amended) A computer program product comprising: 

a computer readable medium having computer program code which enables a 
computer software p rogramming environment with an electronic spreadsheet by: 

defining cells in a spreadsheet that are associated with an iterative process 
repeating for one or more cycles , where the iterative process repeats the same 
action until a condition no longer applies : and 

at each cycle, determining whether to modify content in the cells 
associated with the iterative process , where resulting modified content causes 
changes to computer software being designed using the spreadsheet . 
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92. (Original) A computer program product as in Claim 91 wherein at least one of the cells 
associated with the iterative process includes a final value cell, and at least one of the 
cells includes an initial value cell, where a value in the final value cell is used to modify a 
value in the initial value ceil. 

93. (Original) A computer program product as in Claim 91 wherein the iterative process is 
repeated for either a fixed number of times or imtil a condition defined in a condition cell 
no longer applies, or begins to apply. 

94. (Currently Amended) An apparatus for programming using an electronic spreadsheet 

comprising: 

a computer software programming environment implemented using a spreadsheet; 

[[a]] the spreadsheet having cells that are associated with an iterative process 
repeating for one or more cycles , where the iterative process repeats the same action until 
a condition no longer applies ; and 

content in the spreadshee t causing changes to a computer software program 
implemented by the spreadsheet, such that the computer software program implemented 
by the spreadsheet is b eing modifiable by the iterative process. 

95. (Original) An apparatus as in Claim 94 wherein the modifiable content further includes: 

at least one of the cells associated with the iterative process is a final value cell; 
at least one of the cells associated with the iterative process is an initial value cell; 

and 

a value in the final value cell which influences a value in the initial value cell in 
each cycle of the iterative process. 

96. (Original) An apparatus as in Claim 94 wherein the iterative process is repeated for 
either a fixed number of times or until a condition defined in a condition cell no longer 
applies, or begins to apply. 
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97, (Currently Amended) A data processing system for programming using an electronic 
spreadsheet, the system comprising: 

means for a creating a computer software programming environment including 
computer software implemented using a spreadsheet [[ by ]] : 

[[a]] means for defining cells in a spreadsheet that are associated with an 
iterative process that repeats for one or more cycles , where the iterative process 
repeats the same action until a condition no longer applies : and 

at each cycle, [[a]] means for determining whether to modify content in 
the cells associated with the iterative process , where modified content in the cells 
causes changes to computer software implemented using the spreadsheet. 



98. (New) A method of developing computer software according to Claim 1 further includes 
enabling an event to be defined in one of the cells of one of the spreadsheets, where the 
event includes an event type, an event handler, and an event target. 

99. (New) A computer program product according to Claim 9 fiirther includes instructions 
enabling an event to be defined in one of the cells of one of the spreadsheets, where the 
event includes an event type, an event handler, and an event target. 

100. (New) An apparatus according to Claim 16 fiirther includ e s comprising instructions in 
one of the cells of the spreadsheet enabling an event to be defined, where the event 
includes an event type, an event handler, and an event target. 



